#ifndef LECTEURPHRASEAVECTABLE_H_
#define LECTEURPHRASEAVECTABLE_H_

#include "LecteurSymbole.h"
#include "TableSymboles.h"
#include <string>

using namespace std;

class LecteurPhraseAvecTable {
public:
	LecteurPhraseAvecTable(string nomFich);	// Construit un lecteur de phrase pour vérifier
	                                        // la syntaxe du programme dans le fichier nomFich

	void analyse();   // Si le contenu du fichier est conforme à la grammaire,
	                  //   cette méthode se termine normalement et affiche un message "Syntaxe correcte".
                          //   la table des symboles (ts) aura été construite
	                  // Sinon, le programme sera interrompu (exit).
	inline TableSymboles getTs ()   { return ts; } // accesseur

private:
    LecteurSymbole ls;  // le lecteur de symboles utilisé pour analyser le fichier
    TableSymboles  ts;  // la table des symboles valués
  
    // implémentation de la grammaire
    void programme();   //   <programme> ::= debut <seqInst> fin <EOF>
    void seqInst();	    //     <seq_ins> ::= <inst> ; { <inst> ; }
    void inst();	    //       <inst> ::= <affectation> | <instSi> | <instTq> | <instRepeter>
    void affectation();	// <affectation> ::= <variable> = <expression>
    void expression();	//  <expression> ::= <terme> { <opAdd> <terme> }
    void facteur();     //   <facteur> ::= <entier> | <variable> | <opUnaire> <expBool> | ( <expBool> ) |<CHAINE>
    void terme();       // <terme> ::= <facteur> { <opMult> facteur> }
    void relation(); //<relation> ::= <expression> { <opRel> <expression> }
    void opAdd();   //  <opAdd>  ::= + | - 
    void opMult();   //  <opMult>  ::= *  | /
    void opRel(); // <opRel> ::= == | != | < | <= | > | >=
    void opOu(); //<opOu> ::= ou
    void opEt(); //<opEt> ::= et
    void opUnaire();  //<opUnaire> ::= - | non
    void expBool(); // <expBool> ::= <expBoolEt> { <opOu> <expBoolEt> }
    void expBoolEt(); // <expBoolEt> ::= <relation> { <opEt> <relation> }
    void instSi();   //  <instructSi>  ::= si <expression> alors <seqInst> { sinonsi <expression> alors <seqInst>} [sinon <expression> alors <seqInst>]
    void instTq(); //<instTq> ::= tantque ( <expBool> ) <seqInst> fintantque
    void instPour(); //<instPour> ::= Pour ( <affectation>;<expBool>;<affectation> ) <seqInst> finpour
    void instRepeter(); // <instRepeter> ::= repeter <seqInst> jusqua ( <expBool> )
    void instLire(); // <instLire> ::= lire ( <variable> )
    void instEcrire();  // <instEcrire> ::= ecrire ( <expression> | <chaine> )  
    // outils pour se simplifier l'analyse syntaxique
    void testerSymCour (string ch);  // si symbole courant != ch, erreur : on arrete le programme, sinon rien
    void sauterSymCour (string ch);  // si symbole courant == ch, on passe au symbole suivant, sinon erreur : on arrete
    void erreur (string mess);      // affiche les message d'erreur mess et arrete le programme
};

#endif /* LECTEURPHRASEAVECTABLE_H_ */
